LISTING OF CLAIMS AFTER AMENDMENT 

(Claim 1, currently amended) 

1 . A parallel processing method for performing processing tasks in parallel on 
a plurality of processors comprising: 

(a) identifying at least one area of a large processing task directed to a plurality of 
computational processes that can be grouped together as a task space not dependent on passing of 
control of processing from an external process in order to complete processing of the computational 
processes of the task space; 

(b) breaking down the task space into a plurality of self-contained task objects each 
of which can be executed in one computational step without requiring passing of control to or from 
another object, wherein each task object is defined with a computational step and at least one "data- 
waiting" slot for receipt of data requested from another task object to which the aforesaid task object 
passes a message for the requested data, and wherein once all the "data- waiting" slots of a task object 
are filled by the respective return message(s), the task object can perform its defined computational 
step without waiting for any other input; 

(c) scheduling the defined task objects of said identified task space so that each task 
object ready for processing is to be processed by any a next available "unoccupied" one of the 
plurality of processors, by the sequence of : 

(i) placing a task object with an unfilled "data- waiting" slot in a 
"waiting" state in which it is not assigned to any processor; 

(ii) changing the status of a task object to an "active" state when all of its 
defined "data-waiting" slots have been filled, wherein it is assigned 
to a next available processor in an "unoccupied" state, then placing 
that processor's status in an "occupied" state; and 

(iii) changing the status of the task object to a "dead" state when the 
computational step to be performed for the task obj ect by the assigned 
processor has been completed, and then changing the processor's 
status to an "unoccupied" state to be assigned to a next "active" task 
object. 
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(Claim 2, previously presented) 

2. A parallel processing method according to Claim 1, wherein a master task 
grouping is defined by a plurality of task spaces each of which contains multiple task objects and 
does not require passing of control from an external source in order to complete computation for the 
respective task space. 

(Claim 3, original) 

3 . A parallel processing method according to Claim 2, wherein all task objects of the 
task spaces which are in an f, active" state are placed in a processing queue and each is assigned in turn 
to a next available "unoccupied" processor. 

(Claim 4, original) 

4. A parallel processing method according to Claim 3, wherein a master engine for 
the master task grouping maintains threads which track the processing of task objects in each of the 
task spaces. 

(Claim 5, original) 

5 . A parallel processing method according to Claim 4, wherein the master engine for 
the master task grouping maintains an internal space address assigned to each respective task object. 

(Claim 6, original) 

6. A parallel processing method according to Claim 5, wherein a task object in one 
master task grouping can exchange data with a task object in another master task grouping by 
providing its internal space address indexed to its master task grouping. 

(Claim 7, previously presented) 

7. A parallel processing method according to Claim 1, whereinan identified task in 
computer graphics rendering includes shading an image frame of a scene. 

(Claim 8, original) 

8. A parallel processing method according to Claim 7, wherein the shading task 



includes a master task grouping of shading task spaces each of which performs shading of a pixel 
in the image frame. 

(Claim 9, original) 

9. A parallel processing method according to Claim 8, wherein each shading task 
space includes a plurality of "pixel shading" task objects for performing shading of the pixel based 
upon ray shooting from light sources in the scene, and a "compositing" task object for compositing 
the shading results for the pixel. 

(Claim 10, original) 

10. A parallel processing method according to Claim 9, wherein each shading task 
object has at least one "data-waiting" slot for return of data characterizing light emitted from a 
respective light source in the scene. 

(Claim 11, original) 

1 1 . A parallel processing method according to Claim 9, wherein the rendering task 
includes a function for receiving scene data for a "world map" of the scene, a function for defining 
the scene objects in each frame of the scene, a function for defining the pixels of an object in the 
scene intersected by an eye ray of a viewer of the scene, and a function for tiling together the shading 
results returned by each of the master shading task groupings for respective objects in the image 
frame. 

(Claim 12, currently amended) 

12. A software programming method for performing processing tasks in parallel 
on a plurality of processors comprising: 

(a) identifying at least one area of a large processing task directed to a plurality of 
computational processes that can be grouped together as a task space not dependent on passing of 
control of processing from an external process in order to complete processing of the computational 
processes of the task space; 

(b) breaking down the task space into a plurality of self-contained task objects each 
of which can be executed in one computational step without requiring passing of control to or from 
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another object, wherein each task object is defined with a computational step and at least one "data- 
waiting" slot for receipt of data requested from another task object to which the aforesaid task object 
passes a message for the requested data, and wherein once all the "data- waiting" slots of a task obj ect 
are filled by the respective return message(s), the task object can perform its defined computational 
step without waiting for any other input; 

(c) scheduling defining the defined task objects of said identified task space so that 
each task object ready for processing is to-be processed by any a next available "unoccupied" one 
of the plurality of processors, by the sequence of : 

(i) placing a task object with an unfilled "data-waiting" slot in a 
"waiting" state in which it is not assigned to any processor; 

(ii) changing the status of a task object to an' "active" state when all of its 
defined "data-waiting" slots have been filled, wherein it is assigned 
to a next available processor in an "unoccupied" state, then placing 
that processor's status in an "occupied" state; and 

(iii) changing the status of the task object to a "dead" state when the 
computational step to be performed for the task object by the assigned 
processor has been completed, and then changing the processor's 
status to an "unoccupied" state to be assigned to a next "active" task 
object. 

(Claim 13, previously presented) 

13. A software programming method according to Claim 12, wherein a master task 
grouping is defined by a plurality of task spaces each of which contains multiple task objects and 
does not require passing of control from an external source in order to complete computation for the 
respective task space. 

(Claim 14, original) 

14. A software programming method according to Claim 13, wherein all task objects 
of the task spaces which are in an"active" state are placed in a processing queue and each is assigned 
in turn to a next available "unoccupied" processor. 
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(Claim 15, original) 

1 5 . A software programming method according to Claim 1 4, wherein a master engine 
for the master task grouping maintains threads which track the processing of task objects in each of 
the task spaces. 

(Claim 16, original) 

16. A software programming method according to Claim 15, wherein the master 
engine for the master task grouping maintains an internal space address assigned to each respective 
task object. 

(Claim 17, original) 

17. A software programming method according to Claim 16, wherein a task object 
in one master task grouping can exchange data with a task object in another master task grouping 
by providing its internal space address indexed to its master task grouping. 

(Claim 18, original) 

18. A software programming method according to Claim 12, further comprising 
storing templates for different types of task engines, spaces, and objects in a library and utilizing the 
templates to generate software programming for a desired processing task. 

(Claim 19, previously presented) 

19. A software programming method according to Claim 12, whereinan identified 
task in computer graphics rendering includes shading an image frame of a scene. 

(Claim 20, original) 

20. A software programming method according to Claim 19, wherein the shading 
task includes a master task grouping of shading task spaces each of which performs shading of a 
pixel in the image frame. 
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